package com.xjh.basestudy.algorithmandexercise.sort;

/*
*
选择排序（Selection sort）是一种简单直观的排序算法。它的工作原理是每一次从待排序的数据元素中选出最小
（或最大）的一个元素，存放在序列的起始位置，然后，再从剩余未排序元素中继续寻找最小（大）元素，然后放到
已排序序列的末尾(交换定义的minIndex)。以此类推，直到全部待排序的数据元素排完。 选择排序是不稳定的排序方法*/
//要点:(i=0)目前最小,找出更小,交换位置,按位排序
//自己理解:首先外层for循环认为第一个元素是最小的,
// 内层循环则拿定义的最小的元素的索引和数组中元素逐个比较,如果有更小的
//则把更小的元素定义成最小的元素索引,内层循环完成后查到当前最小的元素和当前正在排序位置的元素的索引比较
//如果不相等(因为首先定义的最小的元素就是当前位置元素,所以内层循环查到的元素只可能相等或者更小),则交换位置
public class SelectSort {
/*    public int[] sort(int arr[]) {
        int temp = 0;
        for (int i = 0; i < arr.length - 1; i++) {
// 认为目前的数就是最小的, 记录最小数的下标
            int minIndex = i;
            for (int j = i + 1; j < arr.length; j++) {
                if (arr[minIndex] > arr[j]) {
// 修改最小值的下标
                    minIndex = j;
                }
            }
// 当退出内层for就找到这次的最小值,就需要交换位置了
            if (i != minIndex) {

//交换当前值和找到的最小值的位置
                temp = arr[i];
                arr[i] = arr[minIndex];
                arr[minIndex] = temp;
            }
        }
        return arr;
    }

    public static void main(String[] args) {
        SelectSort selectSort = new SelectSort();
        int[] array = {2, 5, 1, 6, 4, 9, 8, 5, 3, 1, 2, 0};
        int[] sort = selectSort.sort(array);
        for (int num : sort) {
            System.out.print(num + "\t");
        }
    }*/

//练习一遍:上面是从小到大,这里是从大到小
    public int[] sort(int[] arr){
        int temp = 0;
        for (int i = 0; i < arr.length - 1 ; i++) {
            int maxIndex = i;
            //注意内层循环条件
            for (int j = i + 1; j < arr.length; j++) {
                if(arr[maxIndex] < arr[j]){
                    // arr[maxIndex] = arr[j];是错的,maxIndex定义的是最大值的索引,所以要把最大值的索引赋给它
                    maxIndex = j;
                }

            }
            //arr[maxIndex] != arr[j])  i != maxIndex比较索引和值都可以
            if(arr[maxIndex] != arr[i]){
                temp = arr[i];
                arr[i] = arr[maxIndex];
                arr[maxIndex] = temp;
            }

        }
        return arr;
    }

    public static void main(String[] args) {
        int[] arr = {2, 5, 1, 6, 4, 9, 8, 5, 3, 1, 2, 0};
        SelectSort selectSort = new SelectSort();
        int[] sorted = selectSort.sort(arr);
        for (int num : sorted) {
            System.out.print(num+" ");

        }

    }

}


